

# **IECA**

**Embedded Computer Architecture** 

Lesson 15: Timers in PWM mode



# Timers in PWM mode (not "fast mode")



Duty cycle = 1 - (OCRn / TOP)

#### Output Compare and PWM (not "fast")



#### Timers in fast PWM mode



Duty cycle = 1 - (OCRn / TOP)

### **Output Compare Unit**



#### TIMER 0 and PWM modes



# Timer 0: Compare Unit (8 bit)



### Timer 0: Selecting PWM mode



**TOP** is always 255

#### Timer 0: Output Compare (fast PWM mode)



Table 40. Compare Output Mode, Fast PWM Mode(1)

| COM01 | COM00 | Description                                |  |
|-------|-------|--------------------------------------------|--|
| 0     | 0     | Normal port operation, OC0 disconnected.   |  |
| 0     | 1     | Reserved                                   |  |
| 1     | 0     | Clear OC0 on compare match, set OC0 at TOP |  |
| 1     | 1     | Set OC0 on compare match, clear OC0 at TOP |  |

#### Timer 0: Output Compare (not fast PWM mode)



Table 41. Compare Output Mode, Phase Correct PWM Mode(1)

| COM01 | COM00 | Description                                                                              |
|-------|-------|------------------------------------------------------------------------------------------|
| 0     | 0     | Normal port operation, OC0 disconnected.                                                 |
| 0     | 1     | Reserved                                                                                 |
| 1     | 0     | Clear OC0 on compare match when up-counting. Set OC0 on compare match when downcounting. |
| 1     | 1     | Set OC0 on compare match when up-counting. Clear OC0 on compare match when downcounting. |

#### Timer 0: Output Compare Pin



#### TIMER 1 and PWM modes



# Timer 1: Compare Units (2 sets of 16 bit)



#### Timer 1: Selecting PWM modes



See next slide!

# Timer 1: Selecting PWM modes

| Mode | WGM13 | WGM12<br>(CTC1) | WGM11<br>(PWM11) | WGM10<br>(PWM10) | Timer/Counter Mode of Operation  | ТОР    | Update of<br>OCR1X | TOV1 Flag Set<br>on |
|------|-------|-----------------|------------------|------------------|----------------------------------|--------|--------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                           | 0xFFFF | Immediate          | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit        | 0x00FF | TOP                | воттом              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit        | 0x01FF | TOP                | воттом              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit       | 0x03FF | TOP                | воттом              |
| 4    | 0     | 1               | 0                | 0                | стс                              | OCR1A  | Immediate          | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                  | 0x00FF | TOP                | TOP                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                  | 0x01FF | TOP                | TOP                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                 | 0x03FF | TOP                | TOP                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency Correct | ICR1   | воттом             | воттом              |
| 9    | 1     | 0               | 0                | 1                | PWM, Phase and Frequency Correct | OCR1A  | воттом             | воттом              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct               | ICR1   | TOP                | воттом              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct               | OCR1A  | TOP                | воттом              |
| 12   | 1     | 1               | 0                | 0                | CTC                              | ICR1   | Immediate          | MAX                 |
| 13   | 1     | 1               | 0                | 1                | Reserved                         | _      | _                  | _                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                         | ICR1   | TOP                | TOP                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                         | OCR1A  | TOP                | TOP                 |



**NOTICE: TOP depends on mode!** 



### Timer 1: Output Compare Registers



Notice: 2 16 bit registers: OCR1A and OCR1B.

These names can be used directly in AVR GCC, after #include <avr/io.h>.

#### Timer 1: Waveform gen.(A + B). Fast PWM.



Table 45. Compare Output Mode, Fast PWM(1)

| COM1A1/COM1B1 | COM1A0/COM1B0 | Description                                                                                                                                                            |
|---------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0             | 0             | Normal port operation, OC1A/OC1B disconnected.                                                                                                                         |
| 0             | 1             | WGM13:0 = 15: Toggle OC1A on Compare Match, OC1B disconnected (normal port operation).  For all other WGM13:0 settings, normal port operation, OCnA/OCnB disconnected. |
| 1             | 0             | Clear OC1A/OC1B on compare match, set OC1A/OC1B at TOP                                                                                                                 |
| 1             | 1             | Set OC1A/OC1B on compare match, clear OC1A/OC1B at TOP                                                                                                                 |

Red = The A system.

**Green = The B system.** 

© Ingeniørhøjskolen i Århus iha.dk

#### Timer 1: Waveform gen.(A og B). Not fast PWM.

Bit

Read/Write Initial Value



Table 46. Compare Output Mode, Phase Correct and Phase and Frequency Correct PWM (1)

| COM1A1/COM1B1 | COM1A0/COM1B0 | Description                                                                                                                                                                            |
|---------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0             | 0             | Normal port operation, OC1A/OC1B disconnected.                                                                                                                                         |
| 0             | 1             | WGM13:0 = 9 or 14: Toggle OCnA on<br>Compare Match, OCnB disconnected (normal<br>port operation).<br>For all other WGM13:0 settings, normal port<br>operation, OC1A/OC1B disconnected. |
| 1             | 0             | Clear OC1A/OC1B on compare match when up-counting. Set OC1A/OC1B on compare match when downcounting.                                                                                   |
| 1             | 1             | Set OC1A/OC1B on compare match when up-<br>counting. Clear OC1A/OC1B on compare<br>match when downcounting.                                                                            |

Red = The A system.

**Green = The B system.** 

#### Timer 1: Output Compare Pins



and

### Test ("socrative.com": Room = MSYS)

InitPWM() is initializing the Mega32 Timer 1.
 After this, what value must be written to register OCR1A to obtain a PWM signal with 50% duty

void InitPWM()

cycle?

```
• A: OCR1A = 128;
```

- B: OCR1A = 256;
- C: OCR1A = 512;
- D: OCR1A = 1024;



ОЪОО1ООООО;

TCCR1A = 0b11000011;

TCCR1B = 0b00000001;

### Test ("socrative.com": Room = MSYS)

 The Mega32 Timer 1 is initialized to "10 bit Phase Correct PWM".

The CPU clock frequency is 3,6864 MHz. The Timer 1 clock prescaler is set to 256. What is the <u>frequency</u> of the PWM signal?

• A: About 14 Hz

• B: About 3600 Hz

• C: About 7 Hz

• D: About 1 Hz



#### TIMER 2 and PWM modes



# Timer 2: Compare Unit (8 bit)



# Timer 2 : Selecting PWM modes



**TOP** is always 255

#### Timer 2: Output Compare (fast PWM mode)



**Table 52.** Compare Output Mode, Fast PWM Mode<sup>(1)</sup>

| COM21 | COM20 | Description                                |  |
|-------|-------|--------------------------------------------|--|
| 0     | 0     | Normal port operation, OC2 disconnected.   |  |
| 0     | 1     | Reserved                                   |  |
| 1     | 0     | Clear OC2 on compare match, set OC2 at TOP |  |
| 1     | 1     | Set OC2 on compare match, clear OC2 at TOP |  |

#### Timer 2: Output Compare (not fast PWM mode)



Table 53. Compare Output Mode, Phase Correct PWM Mode(1)

| COM21 | COM20 | Description                                                                              |
|-------|-------|------------------------------------------------------------------------------------------|
| 0     | 0     | Normal port operation, OC2 disconnected.                                                 |
| 0     | 1     | Reserved                                                                                 |
| 1     | 0     | Clear OC2 on compare match when up-counting. Set OC2 on compare match when downcounting. |
| 1     | 1     | Set OC2 on compare match when up-counting. Clear OC2 on compare match when downcounting. |

#### Timer 2: Output Compare Pin



#### End of lesson 15

